Namespaces
Variants

std::literals::chrono_literals:: operator""ms

From cppreference.net
Défini dans l'en-tête <chrono>
constexpr std:: chrono :: milliseconds
operator "" ms ( unsigned long long ms ) ;
(1) (depuis C++14)
constexpr std:: chrono :: duration < /*non spécifié*/ , std:: milli >
operator "" ms ( long double ms ) ;
(2) (depuis C++14)

Forme un littéral std::chrono::duration représentant des millisecondes.

1) Littéral entier, retourne exactement std:: chrono :: milliseconds ( ms ) .
2) Littéral à virgule flottante, retourne une durée à virgule flottante équivalente à std::chrono::milliseconds .

Table des matières

Paramètres

ms - le nombre de millisecondes

Valeur de retour

Le littéral std::chrono::duration .

Implémentation possible

constexpr std::chrono::milliseconds operator""ms(unsigned long long ms)
{
    return std::chrono::milliseconds(ms);
}
constexpr std::chrono::duration<long double, std::milli> operator""ms(long double ms)
{
    return std::chrono::duration<long double, std::milli>(ms);
}

Notes

Cet opérateur est déclaré dans l'espace de noms std :: literals :: chrono_literals , où à la fois literals et chrono_literals sont des espaces de noms inline . L'accès à cet opérateur peut être obtenu avec :

  • using namespace std :: literals ,
  • using namespace std :: chrono_literals , ou
  • using namespace std :: literals :: chrono_literals .

De plus, dans l'espace de noms std :: chrono , la directive using namespace literals :: chrono_literals ; est fournie par la bibliothèque standard , de sorte que si un programmeur utilise using namespace std :: chrono ; pour accéder aux classes de la bibliothèque chrono , les opérateurs littéraux correspondants deviennent également visibles.

Exemple

#include <chrono>
#include <iostream>
int main()
{
    using namespace std::chrono_literals;
    constexpr auto d1{250ms};
    constexpr std::chrono::milliseconds d2{1s};
    std::cout << d1 << " = " << d1.count() << " milliseconds\n"
              << d2 << " = " << d2.count() << " milliseconds\n";
}

Sortie :

250ms = 250 milliseconds
1000ms = 1000 milliseconds

Voir aussi

construit une nouvelle durée
(fonction membre publique de std::chrono::duration<Rep,Period> )